我正在使用geocodergem将地理编码功能添加到我的ActiveRecord模型类之一。这很好用,但我实际上不希望在单元测试期间触发地理编码。我已经尝试通过将此添加到我的RSpec测试来消除对地理编码的调用:before(:each)doUser.stub!(:geocode).and_return([1,1])end但是,当我运行测试时,它似乎仍然在调用地理编码。我做错了什么?仅供引用,如果我在实例级别stub(例如some_user.stub!而不是User.stub!),这一切都有效。 最佳答案 如果你想在实例级别使用st
我正在尝试使用RSpec对我的RESTapi进行功能测试。我希望它的工作方式是使用CI构建来构建我的应用程序并将其部署到云中某处的测试服务器,然后让它启动自动化功能测试。但是为了正确地做到这一点,我需要能够传递应用程序部署位置的基本url/域。它不会是一样的。到目前为止,我发现的所有内容都表明RSpec似乎无法做到这一点。如果我不能在命令行上传递参数,还有另一种方法吗?或者RSpec不是正确的选择吗? 最佳答案 一种方法是使用接受命令行参数的东西绕过对rspec的调用,然后在代码中启动rspec。如果您不想为此编写自己的二进制文件,
在我的一个项目中,我需要与多个后端系统协作。其中一些缺少文档,部分原因是我有一些测试代码与一些测试服务器交互,只是为了查看一切都按预期工作。但是,访问这些服务器非常慢,因此我不想在每次运行测试套件时都运行这些测试。我的问题是如何处理您想跳过某些测试的情况。目前我使用一个环境变量“BACKEND_TEST”和一个条件语句来检查是否为我想跳过的每个测试设置了变量。但有时我想跳过测试文件中的所有测试,而不必在每个测试的开头添加额外的行。需要与测试服务器交互的测试并不多,因为我在其他情况下使用flexmock。但是,您不能mock自己远离现实。从这个问题的标题可以看出,我使用的是Test::U
是的,我开始做这个测试了!但是我不知道该用什么=/Rspec+应该吗?Rspec+牛排?迷你测试?cucumber?capybara?可以吗?(cucumber与Shoulda混合)迷你应该吗?(Minitest与Shoulda混合)啊,这么多选择!我很困惑你们用什么,为什么? 最佳答案 如果您刚刚开始,您应该使用默认值并遵循theofficialguides.重要的是你要练习测试。您使用哪种测试库/框架并不重要——这是一种风格选择,在实际练习测试中是次要的——开始测试Rails应用程序的最简单方法是遵循“Golden官方指南布局的
我想在我的Rails应用程序的Capybara测试套件中使用rspec模拟来阻止登录用户(使用Devise/Warden)。这将节省大量时间,并且意味着我的测试套件可以/将会定期运行。以前,我可以使用authlogic来完成此操作,方法是使用如下代码删除我的session模型:deflogin(user)user_session=mock_model(UserSession,{:user=>user})UserSession.stub(:find).and_return(user_session)end现在我正在使用Devise,我不再有权访问UserSession对象。由于我正在使用
我正在测试对我们API的JSON请求,它将以JSON响应。似乎JSON中的所有整数都被转换为字符串,因为我们将它们发布到Controller考虑操作。Controllerdefconsiderbinding.pry#bindingno#2usedtochecktheparamsafterpostfromtest.ifParametersValidator.is_valid?(params)application_handler=ApplicationHandler.new(request_interactor)renderjson:application_handler.resulte
如何使用回溯创建异常?我知道我们可以做这样的事情来实现这一目标:beginraiseStandardError,"message"rescueStandardError=>exceptionexception.backtraceend或者exception=StandardError.new("message")exception.set_backtrace(caller)但我正在寻找这样的东西:exception=StandardError.new("message",backtrace:caller)有没有一种方法可以使用自定义消息和回溯来初始化异常?
我有一个异常e,我想将它转换成一个与标准ruby输出完全相同的字符串在未捕获异常时在stderr上。初始代码给出了错误的堆栈跟踪顺序,并且缩进不正确。与其编写我自己的代码,我更希望看到一些“oneliner”。你是怎么做到的? 最佳答案 这将是相同的。puts"#{$@.first}:#{$!.message}(#{$!.class})",$@.drop(1).map{|s|"\t#{s}"}或者,使用e:puts"#{e.backtrace.first}:#{e.message}(#{e.class})",e.backtrac
Ruby新手,我想弄清楚使用什么习惯用法来将某些整数值限制为类的构造函数。根据我目前所做的,如果我在initialize()中引发异常,该对象仍会创建,但将处于无效状态(例如,某些nil实例变量中的值)。我不太明白我应该如何限制这些值而不进入看起来不必要的大步骤,例如限制对new()的访问。所以我的问题是,我可以通过什么机制来限制实例化对象的值范围? 最佳答案 嗯,你是完全正确的,即使initialize引发异常,对象仍然存在。然而,任何人都很难坚持引用,除非你从initialize中泄漏self就像我刚写的下面的代码一样:>>cl
我如何使用RSpec测试方法返回包含特定键的散列并且这些键的值不为nil? 最佳答案 我会写:describeMyObjectdodescribe"#my_method"dosubject(:my_method){MyObject.new.my_method}it{is_expected.tobe_a_kind_of(Hash)}specify{expect(my_method.keys).toinclude(:key1,:key2)}specify{expect(my_method.values).not_toinclude(ni